如何知道我们的E2E测试覆盖率?
在单元测试中,很容易知道已经覆盖了哪些代码区域。但是我们能及时知道API调用的动态范围吗?我们一直在思考,既然已经编写了许多 E2E 测试用例,但是我们应该继续编写多少剩余测试?
什么是 Java Agent
什么是Java代理?
Java代理是为应用程序提供检测功能的软件组件。在代理的上下文中 ,检测提供了重新定义在运行时加载的类内容的功能。
幸运的是,我们有 Jacoco 代理。Jacoco 代理是 Java 代理之一,它可以在 JVM 加载类文件时标记类代码,并在调用任何代码后及时计算覆盖范围。我们可以转储覆盖数据并上传到SonarQube以使其可视化,获取最新的Jacoco代理。
我们可以从其官方网站(https://www.eclemma.org/jacoco/)获得最新的 jacoco 代理。请随时将最新的* .zip文件下载到本地计算机并解压缩。只需要使用以下两个文件:
lib / jacocoagent.jar –> Java代理用以标记代码
lib / jacococli.jar –> CLI转储覆盖率数据并生成报告
宿主应用程序启动参数设置
有一种经典的方式(java-jar any.jar)来启动后端服务并设置参数“ -javaagent ”的值。
java
-javaagent:/lib/jacocoagent.jar=includes=*,output=tcpserver,port=6300,address=localhost,append=true -jar MyBackendService.jar
output = tcpserver:这代表JacocoAgent将侦听端口以处理进一步的请求,以下载覆盖数据。
port = 6300:这意味着jacoco代理正在侦听哪个端口。
include =* :这意味着我们可以过滤应该包括哪些源代码。例如include = com.fizz.api。:com.buzz.controller。
如果我们通过 Docker 运行后端服务怎么办?我强烈建议您在 docker 镜像中构建jacocoagent。有一个可能的 Dockerfile 示例,如下所示:
#### Dockerfile #####
ENV JACOCOAGENT_OPTION
-javaagent:/jacocoagent.jar=includes=*,output=tcpserver,port=6300,address=*,append=true
COPY ${JACOCO_AGENT} /jacocoagent.jar
ADD /MyBackendService.jar /App.jar
ENTRYPOINT java ${JACOCOAGENT_OPTION} -server -jar /App.jar
Watch out! Don't forget to expose the port jacocoagent is litening on. docker run -d -p 32399:33399 -p 6300:6300 myBackendServiceImage:latest
转储覆盖率数据
几次之后,我假设您的后端 API 服务已经被调用了很多次。现在是时候转储 coverage 数据了。
java -jar /lib/jacococli.jar dump --address localhost --port
6300 --destfile ./coverage.exec
执行上面的命令以从 jacocoagent tcp 服务器检索 coverage 数据,并将数据写入名为 coverage.exec 的本地文件。
生成可视化报告
覆盖率数据文件(coverage.exec)对任何人都没有意义。我们可以将其可视化为 html 或 xml 报告。这是人类友好的格式。
java -jar /lib/jacococli.jar report ./coverage.exec --classfiles ./build/classes --html htmlReportFolder --xml
xmlReportFileName.xml
–classfiles:此参数是必需的,它必须是已编译的类文件的目录路径。例如,如果使用Maven作为构建工具,则应为“ yourPorjectDirectory / taget / classes”。如果是Gradle,则应为“ yourProjectDirectory / build / classes”。
您应该能够检查 htmlReportFolder 或 xml 文件以立即查看覆盖范围,或者出现了其他意外情况。
将报告上传到SonarQube(可选)
如果您有一个独立的 SonarQube 服务器,这非常好,因为我们可以将覆盖率数据报告上传到 Sonar Web 服务器,以便其他任何人都可以查看。
./mvnw sonar:sonar
-Dsonar.coverage.jacoco.xmlReportPaths=./xmlReportFileName.xml
-Dsonar.java.binaries=./build/classes
-Dsonar.sources=./src/main/java
-Dsonar.inclusions="**/*Api.java,**/*Controller.java"
sonar.coverage.jacoco.xmlReportPaths:我们在上一步中生成的xml报告 文件的完整路径。
sonar.java.binaries:编译的类目录。
sonar.inclusions:这是可选的,您可能想知道仅调用了多少个api。
通常,这是您其中一个可能的解决方案,并且记住仅在基于 JVM 的语言中有效。可视化您的 E2E 测试覆盖范围可以指导回答我们身在何处的问题。